#### **ARCOS Group**

# uc3m Universidad Carlos III de Madrid

## Lesson 5 (III) Memory hierarchy

Computer Structure
Bachelor in Computer Science and Engineering



#### Contents

- Types of memories
- 2. Memory hierarchy
- 3. Main memory
- 4. Cache memory
- 5. Virtual memory

Program: A set of ordered data and instructions



- Program: A set of ordered data and instructions
  - Must be loaded in memory







- Process: program in execution
  - The same program can produce several processes



- Program: A set of ordered data and instructions
  - Must be loaded in memory



#### Memory Image of a Process

Memory image consists of the memory spaces that a process is authorized to use.



## Systems without virtual memory

In systems without virtual memory, the program is completely loaded in memory before the execution



## Systems without virtual memory

Registers are initialized



#### Main memory









#### Sistems without Virtual Memory

- On systems without virtual memory, the program is loaded completely into memory for execution.
- Main problems:
  - If the memory image of a process is larger than the main memory, its execution is not possible.
  - The large size of the memory image of a process may prevent the execution of other processes.



# Hypothetical executable file

```
int v[1000]; // global
int i;
for (i=0; i < 1000; i++)
  v[i] = 0;</pre>
```

#### Hypothetical executable file

```
int v[1000]; // global
int i;
for (i=0; i < 1000; i++)
  v[i] = 0;</pre>
```

```
.data
v: .space 4000
.text
main: li t0, 0
li t1, 0
li t2, 1000
loop: bge t0, t2, end
sw x0, v(t1)
addi t0, t0, 1
addi t1, t1, 4
j loop
end: ...
```

# Hypothetical executable file

```
int v[1000]; // global
int i;
for (i=0; i < 1000; i++)
  v[i] = 0;

assembly</pre>
```

#### executable



Address 2000 is assigned to v Assumes that program starts in address 0

## Loading the program in memory

The Operating System reserves a contiguous free portion in memory for the entire process image



#### Loading the program in memory

- In the executable file the address 0 is considered as the init address
  - Logical address
- ▶ In memory, the init address is I 0000
  - Physical address
- Address translation is needed
  - From logical address to physical
- ▶ The array in memory is in:
  - ▶ The logical address 2000
  - ► The physical address 2000 + 10000
- ▶ This process is called relocation
  - Software relocation
  - Hardware relocation

#### Software relocation

Occurs in the loading process



#### Software relocation

What happens with the instructions loaded in 10012 and 10028 addresses?



# Problem with memory protection

What happens if the program executes these instructions?

```
li t0, 8 sw t0, 0(x0)
```

## Problem with memory protection

What happens if the program executes these instructions?

```
li t0, 8 sw t0, 0(x0)
```

Illegal access to physical address 0 that is not assigned to the program

# Multiprogramming

- ▶ A computer can store several programs in memory
- Each program needs an address space in memory



We need to ensure that a program does not access to the address space of other program

#### Hardware relocation

- ▶ The translation occurs in the execution
- Special HW is needed. Ensure protection



- Limit register: maximum logical address assigned to the program
- Base register: program init address in memory



- Limit register: maximum logical address assigned to the program
- Base register: program init address in memory



- Limit register: maximum logical address assigned to the program
- Base register: program init address in memory



- Limit register: maximum logical address assigned to the program
- Base register: program init address in memory



- Limit register: maximum logical address assigned to the program
- Base register: program init address in memory



# Systems without virtual memory Main problems

- If the process image is bigger than the available memory, the process can not be executed
- ▶ In a 32-bit computer:
  - What is the theoretical maximum size of a program?
  - What if this size if the memory has 512 MB?
- ▶ The number of active programs is reduced

#### Virtual memory

- It is not needed to load the entire process in memory
- Only the program portions needed are loaded in memory
- Main advantages:
  - We can execute a program bigger than the main memory available
  - More programs can be active in memory





## Main concepts on virtual memory

Virtual memory uses:

☐ Main memory: RAM

□ Secondary memory: ssd, disk



## Pages virtual memory

- Processors generate virtual addresses
- The virtual address space is divided in equal size blocks called pages
- Main memory is divided in equal size blocks called page frames
- The part of the disk that supports the virtual memory is divided in equal size blocks called swap pages

#### Physical address and virtual address

- Virtual address space:
  - Memory addresses that use the processor.
- Physical address space:
  - Main memory addresses



# Paged virtual memory

▶ The memory image of the programs are stored in disk















## Paged virtual address



#### Structure of a virtual address

- An bit computer has:
  - Addresses of n bits



Can address 2<sup>n</sup> bytes

#### Structure of a virtual address

▶ Memory image consists of pages with the same size(4 KB, 8 KB)

| n-1                    | 0                     |
|------------------------|-----------------------|
| Page number / Page Id. | Offset / displacement |
| m bits                 | p bits                |

- $\rightarrow$  n = m + p
- ▶ Addressable memory: 2<sup>n</sup> bytes
- ▶ Page size: 2<sup>p</sup> bytes
- ▶ Maximum number of pages: 2<sup>m</sup>





#### Exercise

 A 32 bit computer has a memory of 512 MB and pages of 4 KB

#### Answer:

a) Indicate the format of a virtual address and the number of page frames

#### Solution

#### Virtual address format:



#### Number of page frames

Main memory size 
$$\frac{512 \text{ MB}}{\text{Page size}} = \frac{512 * 2^{20}}{4 \text{ KB}} = \frac{128 * 2^{10}}{4 * 2^{10}}$$



## Page table



## Page table entry



### Page table structure

- Operating system creates the page table when a program is going to be executed
- The page table is accessed by the MMU in the translation process
- The page table is modified by the operating system when a page fail occurs

- Pages of I KB
- Process of 8 KB
  - Number of pages: 8
- Size of sections:
  - Instructions: I.5 KB
  - Data: I KB
  - ► Stack: 0.2 KB

| Instr. | Page 0           |
|--------|------------------|
| Instr. | Page 1           |
| Data   | Page 2<br>Page 3 |
|        | Page 4           |
|        | Page 5           |
|        | Page 6           |
|        | Page 7           |
| Stack  |                  |

- Pages of I KB
- Process of 8 KB
  - Number of pages: 8
- Size of sections:
  - ▶ Instructions: I.5 KB -> 2 pages
  - Data: I KB -> I page
  - Stack: 0.2 KB -> I page

|        | 1      |
|--------|--------|
| Instr. | Page 0 |
| Instr. | Page 1 |
| Data   | Page 2 |
|        | Page 3 |
|        | Page 4 |
|        | Page 5 |
|        | Page 6 |
|        | Page 7 |
| Stack  |        |

- Init virtual address (VA): 0
- Final virtual address: 8191
- Pags. 3, 4, 5 and 6 are not assigned to the program at the beginning

## Example Process image initially in disk

| Instr. | Page 0 |
|--------|--------|
| Instr. | Page 1 |
| Data   | Page 2 |
| Data   | Page 3 |
|        | Page 4 |
|        | Page 5 |
|        | Page 6 |
|        | Page 7 |
| Stack  |        |



# Example OS creates the page table

| Instr. | Page 0 |
|--------|--------|
| Instr. | Page 1 |
| Data   | Page 2 |
| Butu   | Page 3 |
|        | Page 4 |
|        | Page 5 |
|        | Page 6 |
|        | Page 7 |
| Stack  |        |

|                  | P N | M | frame/swaj |
|------------------|-----|---|------------|
| 0                | 0   | 0 | 2          |
| 1                | 0   | 0 | 4          |
| 2                | 0   | 0 | 5          |
| 2<br>3<br>4<br>5 | 0   | 0 | 0          |
| 4                | 0   | 0 | 0          |
|                  | 0   | 0 | 0          |
| 6                | 0   | 0 | 0          |
| 7                | 0   | 0 | 8          |
|                  |     |   |            |

All pages in swap at the begining



### Swap

## Example Access to VA 0









## Swap

## Example Access to VA 0







| Instr. | Pag. 0           |
|--------|------------------|
| Instr. | Pag. 1           |
| Data   | Pag. 2           |
|        | Pag. 3<br>Pag. 4 |
|        | Pág. 5           |
|        | Pag. 6           |
|        | Pag. 7           |
| Stack  |                  |



### Swap

## Example Access to VA 0



# Example handling the page fault







OS reserves a free page frame in memory (5) and copies the block 2 in the frame 5



Pages of the process

0

10

11 12

# Example handling the page fault



| P M frame/swap   |   |   |   |
|------------------|---|---|---|
| 0                | 1 | 0 | 5 |
| 1                | 0 | 0 | 4 |
| 2                | 0 | 0 | 5 |
| 2<br>3<br>4<br>5 | 0 | 0 | 0 |
| 4                | 0 | 0 | 0 |
| 5                | 0 | 0 | 0 |
| 6                | 0 | 0 | 0 |
| 7                | 0 | 0 | 8 |
|                  |   |   |   |



| VA=0 | 0  | 0 |  |
|------|----|---|--|
|      | PN | D |  |

OS updates the page table



#### Swap



|                                 | PN | Л | frame/swap |
|---------------------------------|----|---|------------|
| 0                               | 1  | 0 | 5          |
| 1                               | 0  | 0 | 4          |
| 1<br>2<br>3<br>4<br>5<br>6<br>7 | 0  | 0 | 5          |
| 3                               | 0  | 0 | 0          |
| 4                               | 0  | 0 | 0          |
| 5                               | 0  | 0 | 0          |
| 6                               | 0  | 0 | 0          |
| 7                               | 0  | 0 | 8          |
|                                 |    |   |            |



| VA=0 | 0     | 0   |  |
|------|-------|-----|--|
|      | P.Id. | Off |  |

VA 0 is generated again



#### Swap



#### Memory



### Swap

0

11 12



Memory





Access to memory

Memory

#### Translation



### Memory protection



## Two-level page table



## Inverted page table



## TLB (Translation Lookaside Buffer)

- With virtual memory, two memory accesses are needed for each memory reference:
  - One access to the page table
  - One access to the page in memory
- ▶ TLB is used to optimize the memory access:
  - Table with reduced access time located in the MMU
  - Each entry has the page number and the corresponding page table entry
  - In case of hit, the page table is not accessed
- Two types:
  - ▶ TLB with process identification
  - ▶ TLB without process identification

## TLB without process identification



### TLB without process identification



## Virtual memory and cache memory



## Read access with cache and virtual memory



#### **ARCOS Group**

## uc3m Universidad Carlos III de Madrid

## Lesson 5 (III) Memory hierarchy

Computer Structure
Bachelor in Computer Science and Engineering

